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MEASURING UTILIZATION OF INDIVIDUAL 
COMPONENTS OF CHANNELS 



Technical Field 



This invention relates, in general, to channel 
5 subsystems and, in particular, to measuring utilization of 
individual components of channels of a channel subsystem. 



Background Art 



Historically, the determination of channel utilization 
has been important for capacity planning, problem analysis, 

10 as well as for performance monitoring. Previously, the 
utilization of a channel path has been measured by 
accumulating the amount of time that a channel is busy 
during predefined time intervals. These measurements 
indicate how busy a channel was during each interval, and 

15 based on the measurements, work management and planning 
decisions were made. 



With the advent of more complex channels (e.g., FICON 
(Fibre Connections) channels offered by International 
Business Machines Corporation) , the previous techniques for 

20 measuring channel utilization are inadequate. This is 
because the new channels are considered a collection of 
resources and an indication of the channel being busy does 
not indicate in what capacity it is busy. Thus, a need 
exists for an improved measurement of channel utilization. 

25 In particular, a need exists for a capability that indicates 
what portion of the channel is busy and the particular 
utilization of that channel portion. 
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Summary of the Invention 

The shortcomings of the prior art are overcome and 
additional advantages are provided through the provision of 
5 a method of determining utilization of channel components of 
a computing environment. The method includes, for instance, 
obtaining measurement data for a selected component of a 
channel, in which the channel includes a plurality of 
components; and using the measurement data to determine 
10 utilization of the selected component. 

In one example, the method further includes obtaining 
one or more operational characteristics of the selected 
component, and in yet a further example, the one or more 
operational characteristics are used in determining the 
15 utilization of the selected component. 

In a further aspect of the present invention, a method 
of obtaining information associated with channel components 
of a computing environment is provided. The method 
includes, for instance, selecting a channel within the 
2 0 computing environment to be monitored, the channel including 
a plurality of components; and obtaining data on one or more 
components of the plurality of components. 

In one example, the obtaining data includes obtaining 
one or more operational characteristics of the one or more 
25 components. In a further example, the obtaining data 

includes obtaining measurement data usable in determining 
utilization of the one or more components. 

P0U9- 1999- 0176 -US1 -2- 



In yet a further aspect of the present invention, a 
method of determining utilization of channels of a computing 
environment, in which the computing environment includes a 
plurality of logical partitions, is provided. The method 
5 includes, for instance, obtaining measurement data for a 
channel, and using the measurement data to determine 
utilization of the channel. The measurement data is 
representative of use of the channel by the logical 
partition involved in determining the utilization and of use 
10 by one or more other logical partitions of the plurality of 
logical partitions . 



System and computer program products corresponding to 
the above -summarized methods are also described and claimed 
herein . 



15 Additional features and advantages are realized through 

the techniques of the present invention. Other embodiments 
and aspects of the invention are described in detail herein 
and are considered a part of the claimed invention. 



Brief Description of the Drawings 



2 0 The subject matter which is regarded as the invention 

is particularly pointed out and distinctly claimed in the 
claims at the conclusion of the specification. The 
foregoing and other objects, features, and advantages of the 
invention are apparent from the following detailed 

2 5 description taken in conjunction with the accompanying 
drawings in which: 
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FIG. 1 depicts one example of a computing 
environment incorporating and using the capabilities of 
the present invention; 

FIG. 2a depicts one example of a channel 
5 utilization block used in accordance with an aspect of 

the present invention; 

FIG. 2b depicts one example of a channel 
utilization entry of the channel utilization block of 
FIG. 2a, in accordance with an aspect of the present 
10 invention; 

FIG. 3 depicts one example of a channel subsystem 
extended CPMF data area used in accordance with an 
aspect of the present invention; 

FIG. 4 depicts one embodiment of various 
15 components of a channel of FIG. 1, in accordance with 

an aspect of the present invention; 

FIG. 5 depicts one example of a channel processor 
universal CPMF data area used in accordance with an 
aspect of the present invention; 

2 0 FIG. 6 depicts one embodiment of the logic used to 

set the appropriate mode for a channel processing 
measurement facility used in accordance with an aspect 
of the present invention; 

FIG. 7 depicts one embodiment of the logic 
25 associated with an overview of how to determine 
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utilization of various components of a channel, in 
accordance with an aspect of the present invention; 

FIG. 8 depicts one embodiment of the logic 
associated with an operating system determining the 
5 utilization of one or more channel components, in 

accordance with an aspect of the present invention; 

FIG. 9a depicts one embodiment of a channel 
measurement characteristics block used in accordance 
with an aspect of the present invention; 

10 FIG. 9b depicts one example of information 

included in the CMG-dependent channel measurement 
characteristics field of the block of FIG. 9a, in 
accordance with an aspect of the present invention; 

FIG. 10 depicts one example of the command request 
15 block for a Set Extended Channel Measurements command 

used in accordance with an aspect of the present 
invention; 

FIG. 11 depicts one embodiment of the logic 
associated with a channel processor collecting 
2 0 measurement data for one or more channel components, in 

accordance with an aspect of the present invention; and 

FIG. 12 depicts one embodiment of the logic 
associated with an I/O processor storing measurement 
data for one or more channel components in channel 
25 utilization blocks, in accordance with an aspect of the 

present invention . 
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Best Mode for Carrying Out the Invention 



In accordance with an aspect of the present invention, 
channel utilization is measured. In particular, various 
individual components of a channel are monitored and 
5 measured to determine the utilization of each particular 
component. Further, in accordance with another aspect of 
the present invention, when the system is in logical 
partition mode, the collected measurement data reflects the 
utilization of the channel (or channel component) by a 
10 particular logical partition, as well as the utilization by 
other logical partitions in the system, which are coupled to 
the channel (or channel component) . 

One embodiment of a computing environment incorporating 
and using the channel measurement capabilities of the 

15 present invention is described with reference to FIG. 1. A 
computing environment 100 is based, for instance, on the 
Enterprise Systems Architecture (ESA)/390 offered by 
International Business Machines Corporation, Armonk, New 
York. ESA/390 is described in an IBM publication entitled 

2 0 "Enterprise Systems Architecture/3 90 Principles of 

Operation," IBM Publication No. SA22-7201-06, July 1999, 
which is hereby incorporated herein by reference in its 
entirety. One example of a computing environment based on 
ESA/390 is the 9672 Parallel Enterprise Server offered by 

25 International Business Machines Corporation. 

Computing environment 100 includes, for example, at 
least one central processing complex (CPC) 102 having one or 
more logical partitions (LPARs) 104, a hardware systems area 
(HSA) 106 and at least one channel subsystem 108. 
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The resources of the CPC are allocated to the logical 
partitions. In particular, each logical partition 104 has 
one or more logical processors (not separately shown for 
clarity) , each of which represents all or a share of a 
5 physical processor allocated to the partition. The logical 
processors of a particular partition may be either dedicated 
to the partition (so that the underlying processor resource 
is reserved for that partition) or shared with another 
partition (so that the underlying processor resources are 
10 potentially available to another partition) . 

In the particular example shown, each of logical 
partitions 1-M functions as a separate system having a 
resident operating system 109 (which may differ for each 
logical partition) . In one embodiment, the operating system 
15 is the OS/390 or MVS/ESA operating system offered by 
International Business Machines Corporation. 

Further, each partition has a portion of the CPC ' s main 
storage resources assigned to it and included within the 
storage are channel utilization blocks 110. One example of 
20 a channel utilization block 110 is described with reference 
to FIGs. 2a-2b. 

Referring to FIG. 2a, channel utilization block 110 
includes one or more channel utilization entries 200, each 
of which contains the utilization information for one 
2 5 channel. In one example, channel utilization entry 2 00 
includes the following fields: 

(A) A channel-utilization-information validity 
(CUIV) map 202 that applies to the contents 
of the channel utilization entry. The bits 
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of the CUIV map indicate which words of the 
channel utilization entry contain valid 
channel utilization information; 

(B) A timestamp 2 04 that identifies when channel 
5 utilization information was last stored in 

the channel utilization entry; and 

(C) CMG-dependent channel -utilization information 
206, the contents of which are dependent upon 
the channel measurement group (CMG) to which 

10 the channel belongs. The program can 

determine the CMG for a channel by executing 
a Store Channel Measurement Characteristics 
command (described below) and examining the 
CMG field in the channel measurement 

15 characteristics block (CMCB) (also described 

below) for the associated channel . 

Various examples of values for CMG and the 
corresponding contents of fields of entry 2 00 include the 
following : 

20 CMG=0: A value of 0 in the CMG field indicates 

that the channel -measurement group for the specified 
channel path identifier (CHPID) is unknown. The CUIV 
bits are zeros and the contents of the remainder of the 
channel-utilization entry have no meaning. 

25 CMG=1: The CMG-dependent channel-utilization 

information for CMG=1 includes the following, in one 
example : 
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(A) Channel -Path-Busy Time (CPBT) (CPC) : This 
field contains the accumulation of all 
measured channel -path-busy intervals for the 
associated channel path. The channel path is 
5 busy when it is actively communicating with 

an attached control unit or device. 



When the CPC is operating in LPAR mode, the 
CPBT (CPC) value includes the channel -path- 
busy intervals associated with all of the 
10 logical partitions that have access to the 

associated channel path. 

(B) Channel -Path-Busy Time: When the CPC is 

operating in LPAR mode, the channel path busy 
time contains the accumulation of measured 

15 channel -path-busy intervals for the 

associated channel path. The accumulation 
only includes intervals that are associated 
with the logical partition that has access to 
this channel utilization block. The channel 

20 path is busy when it is actively 

communicating with an attached control unit 
or device. 



When the CPC is operating in basic mode (non- 
LPAR) , the contents of this field have no 
25 meaning and the appropriate bit of the CUIV 

field is zero. 



CMG-2: The CMG- dependent channel -utilization 
information for CMG=2 includes the following, in one 
example : 
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(A) Count of Bus Cycles (CPC) : This field 

contains an accumulated count of the internal 
bus cycles that have been used for I/O 
operations on the associated channel path. 



5 When the CPC is operating in LPAR mode, the 

count includes the internal bus cycles that 
were used for I/O operations for all logical 
partitions that have access to the associated 
channel path. 

10 (B) Count of Channel Work Units (CPC) : This field 

contains an accumulated count of the number 
of channel work units that have been 
performed by the associated channel path. 

When the CPC is operating in LPAR mode, the 
15 count includes the channel work units that 

were performed for all logical partitions 
that have access to the associated channel 
path. 



(C) Count of Channel Work Units: When the CPC is 
2 0 operating in LPAR mode, this field contains 

an accumulated count of the number of channel 
work units that have been performed by the 
associated channel path. The count includes 
only the channel work units that were 
25 performed for the logical partition that has 

access to this channel utilization block. 
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the appropriate bit of the CUIV field is 
zero . 

Count of Data Units Written (CPC) : This field 
contains an accumulated count of the number 
of data units that have been written using 
the associated channel path. 

The channel measurement characteristics block 
for the associated channel path specifies the 
number of bytes contained in a data unit. 

When the CPC is operating in LPAR mode, the 
count includes the data units that were 
written for all logical partitions that have 
access to the associated channel path. 

Count of Data Units Written: When the CPC is 
operating in LPAR mode, this field contains 
an accumulated count of the number of data 
units that have been written using the 
associated channel path. The count includes 
only the data units that were written for the 
logical partition that has access to this 
channel -utilization block. 

When the CPC is operating in basic mode, the 
contents of this field have no meaning and 
the appropriate bit of the CUIV field is 
zero . 

Count of Data Units Read (CPC) : This field 
contains an accumulated count of the number 



of data units that have been read using the 
associated channel path. The channel 
measurement characteristics block for the 
associated channel path specifies the number 
5 of bytes contained in a data unit. 

When the CPC is operating in LPAR mode, the 
count includes the data units that were read 
for all logical partitions that have access 
to the associated channel path. 

10 (G) Count of Data Units Read: When the CPC is 

operating in LPAR mode, this field contains 
an accumulated count of the number of data 
units that have been read using the 
associated channel path. The count includes 

15 only the data units that were read for the 

logical partition that has access to this 
channel-utilization block. 



When the CPC is operating in basic mode, the 
contents of this field have no meaning and 
2 0 the appropriate bit of the CUIV field is 

zero . 



Returning to FIG. 1, coupled to the logical partitions 
is a hardware systems area (HSA) 106 which, in this 
embodiment, includes a channel subsystem extended CPMF data 
25 area 112. The channel subsystem extended CPMF data area 

includes measurement information for individual channels, as 
described with reference to FIG. 3. In particular, for each 
channel, the data area includes, for instance, channel 
measurement characteristics 300, total measurement data 302, 
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and measurement data 3 04 for each particular operating 
system associated with the specified channel. Further 
details regarding these fields are provided below. 



Channel measurement characteristics 3 00 of a channel 
5 include, for example, maximum bus cycles specifying the 
maximum internal bus cycles per second, available for I/O 
operations on the specified channel path; maximum channel 
work units specifying the maximum number of channel work 
units that can be performed per second by the specified 

10 channel paths; maximum write data units specifying the 

maximum number of data units that can be written per second 
using the specified channel path; maximum read data units 
specifying the maximum number of data units that can be read 
per second using the specified channel path; and data unit 

15 size specifying the number of bytes of data that are 

contained in the data unit for the specified channel path. 



Total measurement data 3 02 includes the total 
measurements for specified characteristics of a channel. In 
one example, the total measurement data includes the total 
2 0 bus cycles, the total work units, the total written data 
units and the total read data units, as explained further 
below. 



Additionally, the channel measurement data per 
operating system includes the measurements of the specified 
25 characteristics on a per operating system basis. 

Referring again to FIG. 1, also coupled to the HSA is 
channel subsystem 10 8, which is used in communicating with 
input /output (I/O) devices. Channel subsystem 108 directs 
the flow of information between the input /output devices and 
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main storage. It relieves the central processing units of 
the task of communicating directly with the input /output 
devices and permits data processing to proceed concurrently 
with input/output processing. 

5 In one embodiment, channel subsystem 108 includes one 

or more I/O processors 114 coupled to one or more channels 
116. Further, coupled to each channel is a physical channel 
link 118 that is used to communicate with the I/O devices. 
In particular, in one example, the link couples the channel 
10 to a control unit, which is further coupled to one or more 
I/O devices. 

Further details regarding a channel are described with 
reference to FIG. 4. In one embodiment, each channel 116 
includes, for instance, a channel processor storage 400 

15 coupled to a host -bus bridge and DMA controller 4 02 for 
providing access, via a system bus 4 04, to the operating 
system and other components of the CPC. Additionally, 
coupled to the host -bus bridge and DMA controller is an 
internal bus 406, which is coupled to a channel processor 

2 0 4 08 and an adapter card 410. The adapter card provides 
access to the I/O devices via an external link 412. 

One example of a channel is a FICON channel offered by 
International Business Machines Corporation. One example of 
a FICON channel is described in " IBM S/390 FICON 
25 Implementation Guide", IBM Publication No. SG24-5169-00 
(Nov. 1999) , which is hereby incorporated herein by 
reference in its entirety. 



In one embodiment, channel processor storage 400 
includes a channel processor universal CPMF data area 414 
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used in storing various measurement information for the 
channel. As shown in FIG. 5, channel processor universal 
CPMF data area 412 includes, for instance, channel 
measurement characteristics 500, total channel measurement 
5 data 502, and measurement data 504 for each operating system 
coupled to the channel . 

Channel measurement characteristics data 500 includes, 
for instance, maximum units 506 for a channel component. 
For example, maximum units 506 includes the maximum bus 

10 cycles (e.g., for Component 1 the internal bus) of the 

channel, the maximum channel work units (e.g., for Component 
2 -- the channel processor) , the maximum write data units 
(e.g., for Component 3 the external link), and the 
maximum read data units (e.g., for Component 4 the 

15 external link) for the channel. 

Total channel measurement data 502 includes the total 
measurements for the components (e.g., the total bus cycles, 
total work units, total written data units and the total 
read data units) . 

2 0 Similarly, the operating system measurement data 

includes an operating system timestamp 514, as well as 
accumulated units 516 for each operating system of a 
component. Again, this is the accumulated information for 
each component . 

2 5 Described in detail above is one example of a computing 

environment incorporating and using aspects of the present 
invention. The above -described environment is only one 
example, however. Other computing environments can be used 
without departing from the spirit of the invention. 
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Further, for one or more aspects of the present invention, 
the computing environment need not be in logical 
partitioning (LPAR) mode. Basic mode (non-LPAR) can also 
benefit from aspects of the present invention. 

5 Channel subsystems are further described in Casper et 

al., U.S. Patent No. 5,526,484, entitled "Method and System 
for Pipelining the Processing of Channel Command Words, " 
issued on June 11, 1996, as well as in Galbraith et al . , 
U.S. Patent No. 5,265,250, entitled "Channel Measurement 
10 Method and Means," issued on November 23, 1993, each of 
which is hereby incorporated herein by reference in its 
entirety. 

In accordance with an aspect of the present invention, 
various components of the channel are individually 

15 measurable. These components include, for instance, internal 
bus 406, channel processor 408, and external link 412. By 
measuring these components individually, specific 
information about the individual components, as well as 
about the channel as a whole, can be gathered and employed 

2 0 in work management decisions, billing situations, system 
performance, as well as other areas. 

Each of the various components is measured using a 
channel path measurement facility (CPMF) . The channel path 
measurement facility may be initiated under various 

25 conditions, as described with reference to FIG. 6. As one 
example, the operating system may run the channel path 
measurement facility when an initial program load (IPL) is 
performed, STEP 600. As a further example, the operating 
system runs the channel path measurement facility when an 

30 operator selects an SRM parmlib member using an OS/390 Set 
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command, STEP 602. As a further example, the operating 
system may run the channel path measurement facility when an 
operator configures a channel path (CHPID) online, STEP 604. 



Regardless of the triggering event for initiating the 
5 channel path measurement facility, a determination is made 
as to whether the parmlib specifies a channel path 
measurement facility (CPMF) keyword, INQUIRY 606. In 
particular, a decision is made as to whether the systems 
programmer chose to run with a parmlib member that 

10 specifically indicated the desired CPMF mode (e.g., 

compatibility mode, CPMF=COMPAT, in which the individual 
components are not measured; or extended mode, 
CPMF=EXTENDED , in which the individual components are 
measured in accordance with aspects of the present 

15 invention) . 



If the CPMF keyword was specified, then the system 
operates in the mode selected, STEP 608. However, if the 
systems programmer did not specifically set the CPMF 
parameter, then the operating system chooses the CPMF mode 

2 0 based on the set of channel path ids found in the machine. 
In particular, a determination is made as to whether an 
extended measurement mode CHPID is found, INQUIRY 610. If 
any of the online CHPIDs desire extended mode for gathering 
the performance data, then CPFM is initialized in extended 

25 mode, STEP 612. Otherwise, if no CHPIDs desiring extended 
mode are found, the system runs in the old compatibility 
mode, STEP 614. This completes initialization of the 
channel path measurement facility in the desired mode, STEP 
616. 
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In one embodiment, both the compatibility mode and the 
extended mode can be active at the same time. That is, one 
facility can be activated in one mode, and another facility 
can be activated in another mode. This is true for both the 
5 same logical partition and across multiple logical 
partitions . 

Assuming that the channel path measurement facility is 
set to extended mode, the channel path measurement facility 
collects data on the various components of the channel, in 
10 accordance with an aspect of the present invention. An 

overview of one embodiment of the logic employed to collect 
the various data is described with reference to FIG. 7. 

Initially, a Store Channel Measurement Characteristics 
CHSC command is used by the operating systems to learn about 

15 the measurement characteristics (or attributes) of each 
channel that is to be measured, STEP 700. That is, the 
operating systems learn about the characteristics of the 
various components of the channel to be measured. In one 
example, the measurement characteristics include the maximum 

20 bus cycles, which is an attribute of internal bus 406 (FIG. 
4) ; maximum channel work units, which are attributes of 
channel processor 408; and maximum written/read data units, 
which are attributes associated with external link 412. 
Further, the characteristics include the data unit size. 

2 5 In addition to using the Store Channel Measurement 

Characteristics CHSC command to learn about the measurement 
attributes, a Set Extended Channel Measurements CHSC command 
(described below) is used by the operating system to start 
the channel path measurement facility and to provide to the 
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I/O processor a program data area for the channel 
utilization blocks, STEP 702. 

Thereafter, each channel processor collects measurement 
data, via, for instance, the channel path measurement 
5 facility, for the various channel components contained in 
that channel and places the data in channel processor 
universal CPMF data area 414 (FIG. 4) contained in channel 
processor storage 400. Then, at each proper interval, the 
data is copied from data area 414 to channel subsystem 
10 extended CPMF data area 112 (FIG. 1) for that channel, STEP 
704 . 

Additionally, the I/O processor collects from each of 
the channel subsystem extended CPMF data areas the data for 
all of the channels, reformats it and stores it in the 
15 channel utilization blocks in the previously provided 

program data area, STEP 706. The operating system then 
observes the information that has been placed in the channel 
utilization blocks and is able to interpret the information 
using the measurement characteristics that apply to each 

2 0 channel that were previously gathered (in STEP 700) , STEP 

708. This interpreted information provides the utilization 
of the measured channel components. 

Further details regarding the processing performed by 
the various units of the central processing complex to 
25 measure the utilization of the individual components of a 
channel are described with reference to FIGs. 8-12. In 
particular, FIG. 8 describes one embodiment of the 
processing performed by one or more of the operating 
systems; FIG. 11 depicts one embodiment of the logic 

3 0 performed by one or more of the channel processors; and FIG. 
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12 depicts one embodiment of the logic performed by one or 
more of the I/O processors. 

Referring to FIG. 8, initially, the operating system 
collects the channel measurement characteristics data for 
5 each channel associated with that operating system, using 
the Store Channel Measurement Characteristics CHSC command, 
STEP 800. As one example, the command request block for the 
store command includes an op code specifying the Store 
Channel Measurement Characteristics command, as well as an 
10 identifier for each channel path (CHPID) for which 
information is requested. 

In response to this request, a command response block 
for the Store Channel Measurement Characteristics command is 
provided. This response block includes, for instance, one 

15 or more channel measurement characteristics blocks. In 

particular, a channel measurement characteristics block may 
be stored for one or more of the specified CHPIDs, beginning 
with the CHPID specified by the first CHPID field. One 
example of a channel measurement characteristics block is 

2 0 described with reference to FIG. 9a. 

In one example, a channel measurement characteristics 
block 900 includes, for instance, one or more flags 902, a 
channel path identifier (CHPID) 904, a channel measurement 
characteristics validity (CMCV) indicator 906, a channel 
2 5 measurement group (CMG) 908 and a channel measurement group- 
dependent measurement characteristics field 910, each of 
which is described below. 



Flags 902 provide indicators that enable the proper 
interpretation of the information in the channel measurement 
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characteristics block. As one example, flags 902 include a 
non-valid (N) indicator which, when zero, indicates that 
information is provided in the channel measurement 
characteristics block for the associated channel path. The 
5 CMG and CMCV fields indicate which information is provided. 
When one, the non-valid bit indicates that information is 
not provided for the associated channel path and the CMCV 
field is all zeros. 

Flags 902 also include a shared channel path (S) 
10 indicator, which is meaningful when the N bit is zero and 
the CPC is operating in LPAR mode. When zero, the S bit 
indicates that the associated channel path is not shared 
between the logical partition executing the Store Channel 
Measurement Characteristics command and other logical 
15 partitions. When one, the S bit indicates that the 

associated channel path may be shared between the logical 
partition executing the Store Channel Measurement 
Characteristics command and one or more of the logical 
partitions . 

2 0 CHPID 904 contains the channel path id of the channel 

path with which this channel measurement characteristics 
block is associated. 

Channel measurement characteristics validity (CMCV) 
indicator, when one, indicates that the channel path 
25 measurement facility stores channel measurement 

characteristics information in the corresponding word of the 
channel measurement characteristics block. When zero, a 
CMCV bit indicates that the contents of the corresponding 
word of the channel measurement characteristics block have 

3 0 no meaning. 
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Channel measurement group (CMG) 908 specifies the 
measurement group to which the specified CHPID belongs. 
This value determines the contents and format of the CMG- 
dependent channel measurement characteristics area, and the 
5 format and contents of the channel utilization entry for the 
associated channel path, in the channel utilization block, 
described above. 

CMG -dependent channel measurement characteristics 910 
includes information which is dependent upon the value 

10 specified in the channel measurement group field. For 

instance, a value of zero in the CMG field indicates that 
the channel measurement group for the specified CHPID is 
unknown. Thus, the CMCV bits are zeros and the contents of 
block 910 have no meaning. Further, when CMG=1, the CMCV 

15 bits are zeros, and again, the contents of block 910 have no 
meaning . 

However, when the CMG field contains a value of 2, the 
CMG-dependent channel measurement characteristics include, 
for instance, the following: maximum bus cycles 912 (FIG. 

2 0 9b); maximum channel work units 914; maximum write data 

units 916; maximum read data units 918; and a data unit size 
92 0, each of which is described above. 

Returning to FIG. 8, in addition to collecting the 
channel measurement characteristics data for each channel, 
25 the operating system starts the channel path measurement 
facility using a Set Extended Channel Measurement CHSC 
command, STEP 802. The Set Extended Channel Measurement 
command starts or stops the channel facility based on the 
operation requested in the request block of the command. If 

3 0 the channel path measurement facility is to be started, one 
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facility is provided, when the CPC is operating in basic 
mode. However, when the CPC is operating in LPAR mode, one 
channel path measurement facility is provided for each 
logical partition. The phrase "the channel path measurement 
5 facility" used herein implies the CPC channel path 

measurement facility, when the CPC is operating in basic 
mode, or the channel path measurement facility associated 
with the logical partition executing the command, when the 
CPC is operating in LPAR mode. One example of the request 
10 block used for the Set Extended Channel Measurement command 
is described with reference to FIG. 10. 

In one example, a command request block 10 0 0 for the 
Set Extended Channel Measurement command includes an 
operation code 1002 specifying the operation to be 

15 performed. In one example, this code may indicate a start 
of the channel path measurement facility for the Set 
Extended Channel Measurements command; a stop of the channel 
path measurement facility for the Set Extended Channel 
Measurements command; or a test of the status of the channel 

2 0 path measurement facility for the Set Extended Channel 
Measurement s command . 

Additionally, the command request block includes a key 
1004 used by the channel path measurement facility to access 
the channel utilization block. Further, it includes 

25 utilization block addresses 1006. When the operation code 
specifies a start operation, the channel utilization block 
addresses contain the absolute addresses of, for instance, 
two 4k-byte areas in main storage which collectively make up 
the channel utilization block. Each part (i.e., 4k area) of 

30 the channel utilization block contains utilization 

information for a unique set of a predefined number (e.g., 
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128) of channel paths. When the operation code specifies a 
stop or a test operation, the contents of the channel 
utilization block address is ignored. 

In response to executing the Set Extended Channel 
5 Measurement command, a response block is provided. This 
response block, indicates, for instance, the results of 
executing the Set Extended Channel Measurement command. 

The channel path measurement facility provides the 
program (e.g., operating system) with the ability to 
10 accumulate channel path utilization information, and to 

accumulate the portion of shared channel path utilization 
attributable to a logical partition, when the CPC is 
operating in LPAR mode. 



Returning to FIG. 8, subsequent to starting the channel 
15 path measurement facility, the channel subsystem begins to 
accumulate channel measurement data into the associated 
channel utilization block at predefined intervals (e.g., at 
least once every four seconds), STEP 804. One example of 
how this is performed is described below with reference to 
20 FIGs. 11 and 12. 



Thereafter, the operating system determines the 
utilization of a particular channel component (such as, for 
instance, the channel processor, the internal bus or the 
external link) , which is referred to herein as Component X, 
25 STEP 806. 



One embodiment of how the operating system performs 
this determination is described with reference to STEP 808. 
For example, a copy of the channel utilization block, called 
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Sample # 1, is saved. Then, after a predefined delay (e.g., 
15 seconds) , another copy of the channel utilization block, 
called Sample #2, is also saved. Subsequently, the "change 
in channel Component X units" between the sample periods is 
5 calculated by subtracting the count of channel Component X 
units from Sample # 1 from the count of channel Component X 
units from Sample # 2. (For example, the count of bus 
cycles for the internal bus of Sample # 1 is subtracted from 
the count of bus cycles for the internal bus of Sample # 2 . 
10 Similar computations are made for the various 
characteristics of the other components.) 

Additionally, the "change in channel time" between the 
sample periods is calculated by subtracting the channel 
timestamp for Sample # 1 from the channel timestamp for 

15 Sample # 2. Thereafter, the "average change in channel 

Component X units per second" during this sample period is 
calculated by dividing the change in channel Component X 
units by the change in channel time. The utilization of 
channel Component X, during the sample period, is then 

2 0 calculated by dividing the "average change in channel 
Component X units per second" by the maximum channel 
component units per second from the channel measurement 
characteristics . 



Subsequent to determining the utilization of a channel 
2 5 Component X, processing proceeds to STEP 8 04 in order to 
continue to collect and analyze data for another of the 
various channel components. 



As mentioned above, in addition to the operating system 
performing tasks relevant to determining the utilization of 
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channel components, the channel processor also performs 
various tasks needed to collect measurement data relating to 
a measurable channel component. One embodiment of the logic 
associated with collecting this data is described with 
5 reference to FIG. 11. 

Initially, the channel processor is reset and 
initialized, STEP 1100. Thereafter, the channel processor 
stores its channel measurement characteristics (CMC) into 
the channel subsystem extended CPMF data area in the HSA, 
10 STEP 1102. Subsequently, a determination is made as to 
whether channel work is pending, INQUIRY 1104, In one 
example, this determination is made by checking an internal 
status indicator. If no work is pending, then no data need 
be collected, thus processing continues with INQUIRY 1106. 

15 At INQUIRY 1106, a determination is made as to whether 

a predefined time period (e.g., at least two seconds) has 
passed since the HSA channel measurement data has been 
updated. If the predefined amount of time has not elapsed, 
then processing continues with INQUIRY 1104. However, if 

20 the predefined time interval has passed, then the channel's 
copy of the measurement data is stored into the HSA, STEP 
1108. In particular, the data stored in the channel 
processor universal CPMF data area is copied to the channel 
subsystem extended CPMF data area. Thereafter, processing 

25 continues with INQUIRY 1104. 

At INQUIRY 1104, if channel work is pending, then the 
requested I/O operation is performed for the specified 
operating system, STEP 1110. Additionally, measurement data 
related to the current I/O operation is collected for each 
30 measurable channel component, STEP 1112. The new measurement 
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data is then added to the accumulated measurement data for 
the particular operating system and to the accumulated total 
channel measurement data in the channel processor universal 
CPMF data, STEP 1114. Additionally, the measurement data 
5 timestamp is updated. Thereafter, processing continues with 
INQUIRY 1106. 

Processing related to the I/O processor's collection of 
data is described with reference to FIG. 12. Initially, a 
set loop count is set equal to a variable M, where M is 
10 equal to the number of operating systems, STEP 1200. 
Thereafter, a determination is made as to whether the 
extended channel path monitoring facility is active for this 
operating system, INQUIRY 1202. 

If the facility is not active for this operating 
15 system, then the loop count is decremented by a predefined 
amount (e.g., by one), and a determination is made as to 
whether the last operating system has been processed, 
INQUIRY 1204. If the last operating system has been 
processed, then the logic polls for other IOP work to 
20 perform, STEP 1206. Otherwise, processing continues with 
INQUIRY 12 02 for the next operating system. 

At INQUIRY 12 02, if the extended monitoring facility is 
active for this operating system, then a channel count is 
set equal to a variable, N, which reflects the number of 

2 5 channels, STEP 12 08. Thereafter, the total measurements 
data and the operating system measurement data for the 
channels in which the operating system has access are 
fetched from the channel subsystem extended CPMF data area 
of the HSA and stored into the operating system's channel 

30 utilization blocks, STEP 1210. Subsequently, the variable, 
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channel count, is decremented by a predefined amount (e.g., 
one) , and a determination is made as to whether the last 
channel has been processed, INQUIRY 1212. If the last 
channel has been processed, then processing continues with 
5 INQUIRY 1204. Otherwise, processing continues with STEP 
1210 . 

Described in detail above is a measurement facility 
that measures utilization of individual channel components. 
This advantageously provides utilization information in 

10 enough detail (e.g., work units, data units written, data 
units read and bus cycles used) to effectively assess the 
workload of a channel. Advantageously, measurements are 
provided that are tailored to the type of channel path, and 
which are meaningful in determining how, and to what degree, 

15 the channel is being utilized. The utilization measurements 
of the present invention include information concerning both 
the CPC level and the single logical partition level. In 
addition, in one aspect of the present invention, an 
operating system that is executing in a logical partition 

20 under LPAR is able to observe channel path utilization for 
all logical partitions, as well as for its own logical 
partition. 

Although various components are described herein, this 
invention is not limited to those components. Aspects of 
25 this invention are universal and can be used with a wide 

range of components. Further, the characteristics described 
herein are only examples. Other characteristics can be used 
without departing from the spirit of the present invention. 



The present invention can be included in an article of 
30 manufacture (e.g., one or more computer program products) 
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having, for instance, computer usable media. The media has 
embodied therein, for instance, computer readable program 
code means for providing and facilitating the capabilities 
of the present invention. The article of manufacture can be 
5 included as a part of a computer system or sold separately. 

Additionally, at least one program storage device 
readable by a machine, tangibly embodying at least one 
program of instructions executable by the machine to perform 
the capabilities of the present invention can be provided. 

10 The flow diagrams depicted herein are just examples. 

There may be many variations to these diagrams or the steps 
(or operations) described therein without departing from the 
spirit of the invention. For instance, the steps may be 
performed in a differing order, or steps may be added, 

15 deleted or modified. All of these variations are considered 
a part of the claimed invention. 

Although preferred embodiments have been depicted and 
described in detail herein, it will be apparent to those 
skilled in the relevant art that various modifications, 
2 0 additions, substitutions and the like can be made without 
departing from the spirit of the invention and these are 
therefore considered to be within the scope of the invention 
as defined in the following claims. 
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Claims 



What is claimed is: 



1 1. A method of determining utilization of channel 

2 components of a computing environment, said method 

3 comprising: 

4 obtaining measurement data for a selected 

5 component of a channel, said channel comprising a 

6 plurality of components; and 

7 using said measurement data to determine 

8 utilization of said selected component. 

1 2. The method of claim 1, wherein said obtaining 

2 comprises obtaining measurement data for multiple components 

3 of said plurality of components, and wherein said using 

4 comprises using said measurement data to determine 

5 utilization for each of said multiple components. 

1 3. The method of claim 1, further comprising obtaining 

2 one or more operational characteristics of said selected 

3 component . 

1 4. The method of claim 3, wherein said using further 

2 comprises employing said one or more operational 

3 characteristics to determine said utilization of said 

4 selected component. 
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1 5. The method of claim 4, wherein said obtaining 

2 measurement data comprises obtaining said measurement data 

3 at a plurality of predefined intervals, and wherein said 

4 using comprises: 

5 determining an average change in the measurement 

6 data over at least two intervals of said plurality of 

7 predefined intervals; and 

8 dividing said average change by a value of at 

9 least one of said one or more operational 
10 characteristics . 

1 6. The method of claim 5, wherein said value is a 

2 maximum value for that operational characteristic. 

1 7. The method of claim 3, wherein said selected 

2 component comprises an internal channel bus, and said one or 

3 more operational characteristics of said internal bus 

4 comprise a maximum number of bus cycles. 

1 8. The method of claim 3, wherein said selected 

2 component comprises a channel processor, and said one or 

3 more operational characteristics of said channel processor 

4 comprise a maximum number of channel work units. 

1 9. The method of claim 3, wherein said selected 

2 component comprises an external link of said channel, and 

3 said one or more operational characteristics of said 

4 external link comprise at least one of a maximum number of 

5 written data units, a maximum number of read data units, and 

6 a size of said data units. 
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1 

2 
3 



10. The method of claim 1, wherein said selected 
component comprises one of an internal bus of said channel, 
a channel processor and an external link of said channel. 



1 11. The method of claim 1, wherein the channel is 

2 associated with a logical partition of said computing 

3 environment involved in the determining utilization, and 

4 wherein the measurement data comprises data representative 

5 of use of said selected component by said logical partition. 

1 12. The method of claim 11, wherein the measurement 

2 data is further representative of use of said selected 

3 component by one or more other logical partitions of said 

4 computing environment. 

1 13. The method of claim 1, wherein said obtaining 

2 measurement data is performed using a channel path 

3 measurement facility executing in a first mode. 

1 14. The method of claim 13, wherein another channel 

2 path measurement facility is activated within said computing 

3 environment in a second mode, and wherein said channel path 

4 measurement facility in said first mode and said channel 

5 path measurement facility in said second mode are 

6 concurrently active. 
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15. A method of obtaining information associated with 
channel components of a computing environment, said method 
comprising : 



4 selecting a channel within said computing 

5 environment to be monitored, said channel comprising a 

6 plurality of components; and 

7 obtaining data on one or more components of said 

8 plurality of components. 

1 16. The method of claim 15, wherein said obtaining 

2 data comprises obtaining one or more operational 

3 characteristics of said one or more components. 

1 17. The method of claim 16, wherein at least one of 

2 said one or more operational characteristics comprises a 

3 maximal value of said operational characteristic. 

1 18. The method of claim 15, wherein said obtaining 

2 data comprises obtaining measurement data usable in 

3 determining utilization of said one or more components. 

1 19. The method of claim 15, wherein said obtaining 

2 data comprises: 

3 obtaining one or more operational characteristics 

4 of said one or more components; and 

5 obtaining measurement data for said one or more 

6 components, wherein said one or more operational 

7 characteristics and said measurement data are used to 

8 determine utilization of said one or more components. 
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1 20. A method of determining utilization of channels of 

2 a computing environment, said computing environment 

3 comprising a plurality of logical partitions, and said 

4 method comprising: 

5 obtaining measurement data for a channel, said 

6 measurement data being representative of use of said 

7 channel by a logical partition involved in determining 

8 the utilization and representative of use by one or 

9 more other logical partitions of said plurality of 

10 logical partitions; and 

11 using said measurement data to determine 

12 utilization of the channel. 
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1 21. A system of determining utilization of channel 

2 components of a computing environment, said system 

3 comprising : 

4 means for obtaining measurement data for a 

5 selected component of a channel, said channel 

6 comprising a plurality of components; and 

7 means for using said measurement data to determine 

8 utilization of said selected component. 

1 22. The system of claim 21, wherein said means for 

2 obtaining comprises means for obtaining measurement data for 

3 multiple components of said plurality of components, and 

4 wherein said means for using comprises means for using said 

5 measurement data to determine utilization for each of said 

6 multiple components. 

1 23. The system of claim 21, further comprising means 

2 for obtaining one or more operational characteristics of 

3 said selected component . 

1 24. The system of claim 23, wherein said means for 

2 using further comprises means for employing said one or more 

3 operational characteristics to determine said utilization of 

4 said selected component. 
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1 25. The system of claim 24, wherein said means for 

2 obtaining measurement data comprises means for obtaining 

3 said measurement data at a plurality of predefined 

4 intervals, and wherein said means for using comprises: 

5 means for determining an average change in the 

6 measurement data over at least two intervals of said 

7 plurality of predefined intervals; and 

8 means for dividing said average change by a value 

9 of at least one of said one or more operational 
10 characteristics . 

1 26. The system of claim 25, wherein said value is a 

2 maximum value for that operational characteristic. 

1 27. The system of claim 23, wherein said selected 

2 component comprises an internal channel bus, and said one or 

3 more operational characteristics of said internal bus 

4 comprise a maximum number of bus cycles. 

1 28. The system of claim 23, wherein said selected 

2 component comprises a channel processor, and said one or 

3 more operational characteristics of said channel processor 

4 comprise a maximum number of channel work units. 

1 29. The system of claim 23, wherein said selected 

2 component comprises an external link of said channel, and 

3 said one or more operational characteristics of said 

4 external link comprise at least one of a maximum number of 

5 written data units, a maximum number of read data units, and 

6 a size of said data units. 
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1 30. The system of claim 21, wherein said selected 

2 component comprises one of an internal bus of said channel, 

3 a channel processor and an external link of said channel. 

1 31. The system of claim 21, wherein the channel is 

2 associated with a logical partition of said computing 

3 environment involved in the determining utilization, and 

4 wherein the measurement data comprises data representative 

5 of use of said selected component by said logical partition. 

1 32. The system of claim 31, wherein the measurement 

2 data is further representative of use of said selected 

3 component by one or more other logical partitions of said 

4 computing environment. 
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1 33. A system of obtaining information associated with 

2 channel components of a computing environment, said system 

3 comprising : 

4 means for selecting a channel within said 

5 computing environment to be monitored, said channel 

6 comprising a plurality of components; and 

7 means for obtaining data on one or more components 

8 of said plurality of components. 

1 34. The system of claim 33, wherein said means for 

2 obtaining data comprises means for obtaining one or more 

3 operational characteristics of said one or more components. 

1 35. The system of claim 34, wherein at least one of 

2 said one or more operational characteristics comprises a 

3 maximal value of said operational characteristic. 

1 36. The system of claim 33, wherein said means for 

2 obtaining data comprises means for obtaining measurement 

3 data usable in determining utilization of said one or more 

4 components. 
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1 37. The system of claim 33, wherein said means for 

2 obtaining data comprises: 

3 means for obtaining one or more operational 

4 characteristics of said one or more components; and 

5 means for obtaining measurement data for said one 

6 or more components, wherein said one or more 

7 operational characteristics and said measurement data 

8 are used to determine utilization of said one or more 

9 components . 
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1 38. A system of determining utilization of channels of 

2 a computing environment, said computing environment 

3 comprising a plurality of logical partitions, and said 

4 system comprising: 

5 means for obtaining measurement data for a 

6 channel, said measurement data being representative of 

7 use of said channel by a logical partition involved in 

8 determining the utilization and representative of use 

9 by one or more other logical partitions of said 

10 plurality of logical partitions; and 

11 means for using said measurement data to determine 

12 utilization of the channel. 
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1 39. A system of determining utilization of channel 

2 components of a computing environment, said system 

3 comprising : 

4 at least one processor adapted to obtain 

5 measurement data for a selected component of a channel, 

6 said channel comprising a plurality of components; and 

7 at least one processor adapted to use said 

8 measurement data to determine utilization of said 

9 selected component. 
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1 40. A system of obtaining information associated with 

2 channel components of a computing environment, said system 

3 comprising : 

4 a channel comprising a plurality of components; 

5 and 

6 at least one processor adapted to obtain data on 

7 one or more components of said plurality of components. 
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1 41. A system of determining utilization of channels of 

2 a computing environment, said computing environment 

3 comprising a plurality of logical partitions, and said 

4 system comprising: 

5 at least one processor adapted to obtain 

6 measurement data for a channel, said measurement data 

7 being representative of use of said channel by a 

8 logical partition involved in determining the 

9 utilization and representative of use by one or more 

10 other logical partitions of said plurality of logical 

11 partitions; and 

12 at least one processor adapted to use said 

13 measurement data to determine utilization of the 

14 channel . 
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1 42 . At least one program storage device readable by a 

2 machine, tangibly embodying at least one program of 

3 instructions executable by the machine to perform a method 

4 of determining utilization of channel components of a 

5 computing environment, said method comprising: 

6 obtaining measurement data for a selected 

7 component of a channel, said channel comprising a 

8 plurality of components; and 

9 using said measurement data to determine 
10 utilization of said selected component. 

1 43. The at least one program storage device of claim 

2 42, wherein said obtaining comprises obtaining measurement 

3 data for multiple components of said plurality of 

4 components, and wherein said using comprises using said 

5 measurement data to determine utilization for each of said 

6 multiple components. 

1 44. The at least one program storage device of claim 

2 42, wherein said method further comprises obtaining one or 

3 more operational characteristics of said selected component. 

1 45. The at least one program storage device of claim 

2 44, wherein said using further comprises employing said one 

3 or more operational characteristics to determine said 

4 utilization of said selected component. 
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1 46. The at least one program storage device of claim 

2 45, wherein said obtaining measurement data comprises 

3 obtaining said measurement data at a plurality of predefined 

4 intervals, and wherein said using comprises: 

5 determining an average change in the measurement 

6 data over at least two intervals of said plurality of 

7 predefined intervals; and 

8 dividing said average change by a value of at 

9 least one of said one or more operational 
10 characteristics . 

1 47. The at least one program storage device of claim 

2 42, wherein said selected component comprises one of an 

3 internal bus of said channel, a channel processor and an 

4 external link of said channel. 

1 48. The at least one program storage device of claim 

2 42, wherein the channel is associated with a logical 

3 partition of said computing environment involved in the 

4 determining utilization, and wherein the measurement data 

5 comprises data representative of use of said selected 

6 component by said logical partition. 

1 49. The at least one program storage device of claim 

2 48, wherein the measurement data is further representative 

3 of use of said selected component by one or more other 

4 logical partitions of said computing environment. 
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1 50. An article of manufacture, comprising: 

2 at least one computer usable medium having 

3 computer readable program code means embodied therein 

4 for causing the obtaining of information associated 

5 with channel components of a computing environment, the 

6 computer readable program code means in the article of 

7 manufacture comprising: 

8 computer readable program code means for 

9 causing a computer to select a channel within said 

10 computing environment to be monitored, said 

11 channel comprising a plurality of components; and 

12 computer readable program code means for 

13 causing a computer to obtain data on one or more 

14 components of said plurality of components. 

1 51. The article of manufacture of claim 50, wherein 

2 said computer readable program code means for causing a 

3 computer to obtain data comprises computer readable program 

4 code means for causing a computer to obtain one or more 

5 operational characteristics of said one or more components. 

1 52. The article of manufacture of claim 50, wherein 

2 said computer readable program code means for causing a 

3 computer to obtain data comprises computer readable program 

4 code means for causing a computer to obtain measurement data 

5 usable in determining utilization of said one or more 

6 components . 
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1 53. The article of manufacture of claim 50, wherein 

2 said computer readable program code means for causing a 

3 computer to obtain data comprises: 

4 computer readable program code means for causing a 

5 computer to obtain one or more operational 

6 characteristics of said one or more components; and 

7 computer readable program code means for causing a 

8 computer to obtain measurement data for said one or 

9 more components, wherein said one or more operational 

10 characteristics and said measurement data are used to 

11 determine utilization of said one or more components. 
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1 54 . At least one program storage device readable by a 

2 machine, tangibly embodying at least one program of 

3 instructions executable by the machine to perform a method 

4 of determining utilization of channels of a computing 

5 environment, said computing environment comprising a 

6 plurality of logical partitions, and said method comprising 

7 obtaining measurement data for a channel, said 

8 measurement data being representative of use of said 

9 channel by a logical partition involved in determining 

10 the utilization and representative of use by one or 

11 more other logical partitions of said plurality of 

12 logical partitions; and 

13 using said measurement data to determine 

14 utilization of the channel. 



* * * * * 
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MEASURING UTILIZATION OF INDIVIDUAL 
COMPONENTS OF CHANNELS 

Abstract of the Disclosure 

The utilization of various individual components of a 
channel is determined in order to learn which portion of a 
channel is busy and to what extent that portion is busy. 
The determination of a component's utilization is dependent 
on the type of component, as well as the operational 
characteristics of that component. 
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CHANNEL UTILIZATION BLOCK 



CHANNEL UTILIZATION ENTRY 
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fig. 2A 
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CHANNEL SUBSYSTEM EXTENDED CPMF DATA 



CHANNEL 0 MEASUREMENT CHARACTERISTICS -"Z^-300 
CHANNEL 0 TOTAL MEASUREMENT DATA "2^302 
CHANNEL 0 MEASUREMENT DATA O/S 0 "^304 

// REPEATED FOR 0/S 1-(M-1) // 
CHANNEL 0 MEASUREMENT DATA O/S M 



// REPEATED FOR CHANNELS 1-(N-1) // 



CHANNEL N MEASUREMENT CHARACTERISTICS -Z^300 
CHANNEL N TOTAL MEASUREMENT DATA —2^*302 
CHANNEL N MEASUREMENT DATA O/S 0 -~2^304 

// REPEATED FOR O/S 1-(M-1) // 

CHANNEL N MEASUREMENT DATA O/S M 



fig. 3 
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CHANNEL PROCESSOR UNIVERSAL CPMF DATA 
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DATA 



// 



REPEATED OF O/S 2-(M-1) 




504 



O/S M TIMESTAMP 
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USING THE STORE CHANNEL MEASUREMENT 
CHARACTERISTICS CHSC COMMAND, THE OPERATING 
SYSTEMS LEARN ABOUT THE MEASUREMENT ATTRIBUTES 
OF EACH CHANNEL THAT IS TO BE MEASURED 



^~700 




USING SET EXTENDED CHANNEL MEASUREMENT 
CHSC COMMAND, OPERATING SYSTEM STARTS 
CHANNEL PATH MEASUREMENT FACILITY AND 
PROVIDES PROGRAM DATA AREA FOR CHANNEL 
UTILIZATION BLOCKS TO I/O PROCESSOR 


\ 




EACH CHANNEL PROCESSOR COLLECTS MEASUREMENT 
DATA FOR THE VARIOUS CHANNEL COMPONENTS 
CONTAINED IN THAT CHANNEL AND HOLDS DATA IN 
CHANNEL PROCESSOR UNIVERSAL CPMF DATA AREA 
CONTAINED IN CHANNEL PROCESSOR STORAGE. AT 
PROPER INTERVAL, COPY DATA TO CHANNEL SUBSYSTEM 
EXTENDED CPMF DATA AREA FOR THAT CHANNEL 


) 


s-706 


I/O PROCESSOR COLLECTS AND REFORMATS DATA FOR 
ALL OF THE CHANNELS FROM EACH OF THE CHANNEL 
SUBSYSTEM EXTENDED CPMF DATA AREAS AND 
STORES IT IN THE CHANNEL UTILIZATION 
BLOCKS IN PROGRAM DATA AREA 




s-708 


THE OPERATING SYSTEM OBSERVES THE INFORMATION 
THAT HAS BEEN PLACED IN THE CHANNEL UTILIZATION 
BLOCKS AND IS ABLE TO INTERPRET IT USING THE 
MEASUREMENT ATTRIBUTES THAT APPLY TO EACH 
CHANNEL THAT WERE GATHERED IN STEP ONE ABOVE. 



fig. 7 
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OPERATING SYSTEM (O/S) ^n^-8 00 

COLLECT CHANNEL MEASUREMENT CHARACTERISTICS 
DATA FOR EACH CHANNEL USING STORE CHANNEL 
MEASUREMENT CHARACTERISTICS CHSC COMMAND j 

j /-l^ 8Q2 

START THE CHANNEL PATH MEASUREMENT FACILITY 
USING THE SET EXTENDED CHANNEL MEASUREMENT 
CHSC COMMAND. 
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THE CHANNEL SUBSYSTEM BEGINS TO STORE CHANNEL 
MEASUREMENT DATA INTO THE O/S's CHANNEL 
UTILIZATION BLOCK (CUB) IN STORAGE EVERY 4 SECONDS. 
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TO DETERMINE THE UTILIZATION OF CHANNEL 
COMPONENT X, THE O/S DOES THE FOLLOWING: 








i S^-808 



1) SAVE A COPY OF THE CUB CALLED SAMPLE #1, 
DELAY FOR A WHILE, AND THEN SAVE ANOTHER 
COPY OF THE CUB CALLED SAMPLE §2. 



2) CALCULATE THE "CHANGE IN CHANNEL COMPONENT 
X UNITS" BETWEEN THE SAMPLE PERIODS BY SUB- 
TRACTING COUNT OF CHANNEL COMPONENT X UNITS 
FOR SAMPLE #1 FROM COUNT OF CHANNEL COMPONENT 
X UNITS FROM SAMPLE §2. 

3) CALCULATE THE "CHANGE IN CHANNEL TIME" BETWEEN 
THE SAMPLE PERIODS BY SUBTRACTING THE CHANNEL 
TIMESTAMP FOR SAMPLE #1 FROM THE CHANNEL TIME- 
STAMP FOR SAMPLE §2. 

4) CALCULATE THE "AVERAGE CHANGE IN CHANNEL 
COMPONENT X UNITS PER SECOND" DURING THE 
SAMPLE PERIOD BY DIVIDING THE "CHANGE IN 
CHANNEL COMPONENT X UNITS" BY THE "CHANGE IN 
CHANNEL TIME". 

5) CALCULATE THE UTILIZATION OF CHANNEL COMPONENT 
X DURING THE SAMPLE PERIOD BY DIVIDING THE 

AVERAGE CHANGE IN CHANNEL COMPONENT X UNITS 
PER SECOND BY THE MAXIMUM CHANNEL COMPONENT 
UNITS PER SECOND FROM THE CHANNEL MEASUREMENT 
CHARACTERISTICS. 



fig. 8 
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RESET AND INITIALIZE CHANNEL PROCESSOR 
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STORE CHANNEL MEASUREMENTS 
CHARACTERISTICS INTO THE CMC HSA AREA. 
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PERFORM I/O OPERATION FOR O/S X 
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COLLECT MEASUREMENT DATA RELATED TO THE 
CURRENT I/O OPERATION FOR EACH MEASUREABLE 
CHANNEL COMPONENT 
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ADD THE NEW MEASUREMENT DATA TO THE 
ACCUMULATED MEASUREMENT DATA FOR O/S 
X AND ALSO TO THE ACCUMULATED TOTAL 
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